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HTLE OF INVENTION 
Electronic Program Guide Schedule Localization System and Method 
FIELD OF INVENTION 
The present invention relates to a television program guide 
("EPG**), and, in particular, to a system and method for "localizing" a national 
EPG schedule to filter out schedule urformation not relevant to a viewer's service 
environment. 

BACKGROUND OF INVENTION 

There are known EPG systems which provide television viewers 
with on-screen program schedule mformation in a convenient format. In so-called 
interactive EPGs, the operation of the EPG is under user control so that the user 
may browse schedule information in any order, select programs from on-screen 
menus for current or future viewing, order pay-per-view programming and 
perform other useftil operations on demand. An example of an advanced EPG 
system is described in co-pending application serial no. 08/119367 by Bennington, 
et al., entitled "Electronic Television Program Guide Schedule System and 
Method" (hereinafter, "Bennington et al."), incorporated herein by reference. 

Most EPGs operate in the following basic manner: program 
schedule information, and sometimes applications and/or systems software, is 
transmitted to equipment located on the viewer's premises (usually a "set-top 
box") by way of broadcast, cable, dkect satellite or some other suitable form of 
transmission. The set-top box contains memory so that the program schedule 
information can be retained for later viewing. The program schedule information 
stored in the set-top box is periodically updated (e.g., on a continuous, daily, 
weekly, bi-weekly basis). A programmed microcontroller in the set-top box 
cooperates with the viewer's television set to display the stored program schedule 
information and to implement other functions of the EPG in response to user- 
generated signals. The functions available will depend on the sophistication of the 
particular EPG. 
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Currently, the television programming available to a viewer depends 
on the service provider servicing the viewer's region. For example, in the U.S., 
cable operators are usually given a franchise from the local government to provide 
cable service to a particular locale. This means that, in general, program 
schedules will vary according to region. 

It would be advantageous to publishers of program guides on a 
national scale, e.g., TV GUIDE, to be able to transmit a single, national program 
schedule to all participating service providers in diverse geographic regions. In 
this way, the EPG publisher would avoid the cost and complexity of having to 
route schedule information according to destination, which would require multiple, 
geographically targeted transmissions. At the same time, it would also be 
desirable to "localize" the national feed, tailoring the schedule to each locale, 
without adding to the cost and complexity of the service provider's transmission 
equipment. 

BRIEF SUMMARY OF INVENTION 
These and other objects are accomplished in accordance with the 
present invention by an EPG program schedule localization system and method in 
which a national program schedule feed is "localized" by a schedule information 
filter implemented in each viewer's set-top box. The localization filter 
automatically recognizes which schedule information is relevant to the viewer's 
service environment and stores or rejects the information accordingly. The result 
is an electronic program schedule that is tailored to the viewer's specific service 
environment without the use of costly equipment on the transmission side of the 
program schedule feed. And, because only one copy of the program schedule data 
is required to serve multiple locales, the total amount of data to be sent is 
minimized, further reducing costs. The single program feed of the present 
invention has the further advantage of decreasing transmission time, which means 
that schedule data reaches subscribers more quickly. In other embodiments of the 
invention, some of the localization filtering is performed at the subscriber's 
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headend, thus freeing up transmission bandwidth on the medium connecting the 
subscriber's set-top box widi the headend. 

BRIEF DESCRIPTION OF THE DRAWINGS 
Fig. 1 is an overview of an illustrative embodiment of the present 

5 invention; and 

Fig. 2 shows the localization information filter of the present 

invention. 

DETAILED DESCRIPTION OF A PREFERRED EMBODIMENT 
The system and method of the present invention may be 

10 implemented on any suitable EPG platform having storage means for storing 
program schedule information, programmed processor means for executing a 
memory management software program in accordance with the invention's various 
memory management functions, and a clock for keeping track of the current date 
and time. The program of the present invention may be stored in a separate 

IS storage means or in a separate portion of the same storage means used for the 
schedule information. The coding of a program to carry out the information 
filtermg procedures of the present invention will be readily apparent to the 
ordinarily-skilled programmer. 

A suitable platform for implementing the present invention is the 

20 EPG of Bennington, et al., mentioned above. Referring to Figure 1 of 

Bennington, et al., the program of the present mvention is loaded into and stored 
in non-volatile memory EEPROM 20. Schedule information in this platform is 
stored in a database constructed in DRAM 18. As explained in Bennington, et al., 
no special transmission protocols are required to send and receive program 

25 schedule information. The construction and organization of the program schedule 
database are routine tasks, as the ordinarily-skilled artisan will appreciate. 

Microcontroller 16 provides a suitable processor means for 
executing the program of the present invention, and the clock 19 keeps track of the 
current time and date (for comparing against schedule records). Other suitable 

30 hardware configurations will occxu- to diose skilled in the art to which the present 
invention pertains. The present invention is not directed to the particular details of 
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the display means of the EPG» and, to avoid obscuring the present invention, the 
operation of such elements will not be discussed here. 

Fig. 1 presents an overview of the invention, using a cable system 
and national schedule feed as examples. The present invention may, however, be 
5 used with any mode of transmission (e.g., direct broadcast satellite), as will be 
readily apparent. The present invention is not directed to the particular mode of 
transmitting the program schedule feed, nor is it lunited to any particular feed 
scope. Referring to Fig. 1, a national electronic program schedule feed 10 is 
transmitted by suitable means (e.g., satellite) to a viewer's cable "headend" 

10 antennae 20, which drives the local CATV distribution network. This same 

national feed 10 is sent to all service providers with whom the EPG publisher has 
made appropriate arrangements for reception and distribution of the schedule. The 
geography served by the EPG schedule publisher is limited only by the reach of 
the service providers acceptmg the national feed. In some preferred embodiments 

15 of the present invention, a complete new schedule is sent to subscribers on a daily, 
weekly, or some other periodic basis. In other prefened embodiments, the system 
does not wait until a complete new schedule is ready to be transmitted before 
updating the EPG. Rather, incremental updates to the program schedule are 
continuously sent to subscribers. In diis "cyclical" mode of operation, when all of 

20 the data in a schedule has been sent, transmission of schedule data updates 

inunediately begins. Each subsequent transmission includes updates to schedule 
information akeady stored in the EPG as well as new data for the end of the 
covered time period. Any schedule data that has expired since the last 
transmission is not sent. 

25 Signal processing equipment 30 located at the headend conditions 

the received signals for distribution to end users via the distribution hub 40. Note 
at this point that no filtering of the electronic program schedule has been 
performed, and that no special equipment at the headend has been introduced. 
Hub 40 next distributes the national program schedule 10 to each subscriber 50 

30 serviced by that hub. The schedule 10 is received by the set-top box 52 located on 
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the viewer's premises, where the schedule is localized according to the present 

mvention for display on the viewer's television receiver 54. 

Referring now to Fig. 2, the information localization filter 53 of the 

present invention is implemented in the set top box 52 as follows. The overall 
5 object is to transform the national program schedule 10 into a localized version 55 

which is then stored in the set-top box storage means 56 (designated DRAM 16 in 

Fig. 1 of Bennington, et al.). In this illustrative embodiment, the localization 

filter 53 is implemented in the EPG software program running on the set-top bdx. 

The filter may, however, be implemented in dedicated hardware filters configured 
10 to execute the procedures described below. Those skilled in the art will readily 
* understand how to construct a hard-wired version of the filtering system and 

method herem described. A combination of hardware and software filters may 

also be used. 

Each set-top box 52 is assigned to a number of "groups. " In the 
15 preferred embodunent, set-top groups would include groups corresponding to the 
viewer's: 

cable operator (e.g., TCI) 
geographic region (e.g., Colorado) 
particular cable system (e.g. Mile Hi Cablevision) 
20 - cable headend (e,g., Denver headend) 

subscribers paying for a particular rate for service 
(e.g., within the City of Denver cable franchise) 
EPG software version (deluxe application, etc.) 
The groups are numbered (e.g., EPG software version=2, geographic region=3, 
25 cable operator=4, cable system=5, cable headend=6, subscriber group=7, etc.) 

for easy identification and for other reasons explained later. Hereinafter, the term 
"scope** will be used to refer to a collection of groups of the same type, e.g., all 
cable operators, whereas "group" will be used to refer to specific members within 
the corresponding scope. In addition, each group is assigned a range of numbers 
30 for purposes of identifymg specific members of the corresponding scope (e.g., 1- 
200 for cable operators, 201-500 for geographical region, etc.). 
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Prior to receiving schedule information for the first time, each set- 
top box 52 is sent a set of group numbers corresponding to all of the specific 
groups of which it is a member. The group numbers may be sent to the set-top 
box via any of the methods discussed in Bennmgton, et ai. This set of group 
5 numbers provides the fdtering criteria by which schedule information on the 

national feed is localized. This is made possible by addressing all of the program 
schedule data in die national feed 10 by group number and comparing the data's 
group addresses with the set of group numbers stored in the viewer's set-top box 
52. If the data is addressed to a group number that is not found in the set-top 

10 box, that data is rejected by the localization filter 53* If, on the other hand, a 

match between the program data address and a group number in the set-top box is 
found, then the data corresponds to programming available in the viewer's service 
area and is accordingly stored in the program schedule database 56. Data intended 
for all subscribers nationwide is addressed without a group number. The 

15 information fdter 53 is configured to pass all such data addressed without a group 
number. Only the schedule information corresponding to the viewer's own service 
area is passed on to the EPG memory by the information filter 53, thereby 
"localizing" the national feed 10. At the same time, the present invention 
conserves system memory by rejecting extraneous program schedule information 

20 not relevant to the viewer's service environment. 

By way of example, a data item corresponding to a program 
available nationwide, such as the program's description, would be addressed 
without a group number to ensure that such data is loaded into the schedule 
database 56. By contrast, data corresponding to programmmg available only 

25 locally would be addressed to the unique group number associated with the 

locale(s) m which the program is available. In a like maimer, all of the data in the 
national feed is addressed by attaching a group number correspondmg to the 
desired destmation. 

In another aspect of dae present invention, each data item filtered m 

30 the localization filter 53 prior to storage in the EPG's memory 56 is tagged with 
the scope number on which it has been fdtered. Higher scope numbers are 
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assigned to more narrowly targeted data (e.g., cable headend =6 versus geographic 
region=3), as shown in the example above. A higher scope number reflects the 
greater utility of data with a more local (narrow) orientation. The specific scope 
numbers used here are merely exemplary, and are not critical to the operation of 

5 the invention. Tagging filtered data with its corresponding scope number is useful 
in cases where the same data item is sent multiple times with group numbers 
falling within more than one scope. This situation might arise where the price 
data for a pay-per-view program varies depending on the cable system (scope—5) 
within the cable operator's (scope=4) service area. In that situation, the price 

10 corresponding to the more narrowly scoped version of the data would be more 
useful than the more widely scoped version. Accordmgly, if the set-top box 
software running the EPG program receives multiple copies of the price data, only 
the most narrowly scoped version, i.e., the one of most interest, of the data is 
retained. Where the most narrowly scoped version is abeady loaded in the 

15 program database 56, differently scoped versions of the data are discarded by the 
fdter 53 as soon as they are received. If a more widely scoped version of a 
particular data item is received first, it is saved until a more narrowly scoped 
version is received, at which pomt the widely scoped version is replaced with the 
version having a more narrow scope. 

20 In another embodiment of the present invention, some of the 

filtering performed at the set-top box is performed at the headend. Referring 
again to Fig. 1, the signal processing means 30 located at the headend is 
provisioned with an information filter that is configured in the same way as the 
set-top boxes connected to the headend, except that no filtering is performed for 

25 data scoped more narrowly than headend. This arrangement eliminates data which 
is not needed by any set-top box connected to that headend, fi'eeing up 
transmission bandwidth in the path connecting the headend and the associated set- 
top boxes. The headend could use this bandwidth to increase the frequency at 
which program schedule data is sent to subscribers, in a sense "concentrating" the 

30 data transmitted on the national feed 10. This in turn would facilitate the use of 
slower data rates to transmit the national feed 10 to the headend, reducing costs. 
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As should be apparent from the above description, the present 
invention provides a flexible and cost effective means for localizing a national 
program schedule feed. By distributing the filtering intelligence to the edges of 
the schedule distribution network, the present invention eliminates the costs and 
5 complexities associated with multiple, individually-targeted transmissions and 

reduces the bandwidth necessary to transmit schedule information at a given rate. 

It will be appreciated that although the present invention has been 
described by reference to particular embodunents, many other embodiments may 
be implemented without departing from the spirit and scope of the invention as set 
10 forth in the following claims. 
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We claim: 

1. In a television electronic program guide (EPG) system, 
including means for receiving program schedule information, means for storing the 
program schedule information, means for executmg an EPG program and display 
means for displaying schedule information on-screen, a program schedule 
localization system comprising: 

a) means for receiving aggregated program schedule information for 
a plurality of service environments; 

b) means for identifying the program schedule information 
corresponding to a viewer's service environment; 

c) means for discarding program schedule information 
corresponding to service environments outside the viewer's; and 

d) means for storing the program schedule information not 

discarded. 

2. The schedule localization system according to claim 1 wherein a 
viewer's service environment is identified by a set of service groups to which the 
viewer is assigned, each service group identifying the service environment with a 
different level of specificity. 

3. The schedule localization system according to claim 2 wherein 
schedule data in the aggregated program schedule intended for a selected service 
environment includes address data representing the service group to which such 
schedule data pertains. 

4. The schedule localization system according to claim 3 wherem the 
means for identifying the program schedule information corresponding to a 
viewer's service environment includes means for storing data representing each of 
the service groups to which the viewer is assigned and means for comparing the 
address data in the aggregated program schedule with the stored service group 
data. 
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5. The schedule localization system according to claim 4 wherein 
schedule information in the aggregated program schedule intended for a selected 
service environment is stored if a match is found between the address data 
associated with such schedule information and the stored service group data 

5 representing at least one service group in the set of service groups to which the 
viewer is assigned. 

6. The schedule localization system according to claim 5 further 
comprising means for providing an indication of the level of service environment 

10 specificity of each service group stored in the means for storing service group data 
and means for tagging stored schedule information with the indication 
corresponding to the service group on which a match with the address data of such 
schedule information was found. 

15 7. The schedule localization system accordmg to claim 6 further 

comprising means for replacing stored schedule information wifli a new version of 
such schedule information if the service environment specificity indication 
associated with such new version is more specific to the viewer's service 
environment than the service environment specificity mdication associated with the 

20 already stored schedule information. 

8. The schedule localization system according to claim 7 further 
comprising means for rejecting a new version of schedule information ahready 
stored if the service environment specificity indication associated with such new 

25 version is less specific to the viewer's service environment than the service 
environment specificity indication associated with the akeady stored schedule 
information. 

9. The schedule localization system according to claim 2 wherein the 
30 service groups include geographic region and service provider. 

10 
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10. In a television electronic program guide (EPG) system, including 
means for receiving program schedule information, means for storing the program 
schedule information, means for executing an EPG program and display means for 
displaymg schedule information on-screen, a program schedule localization method 
comprising the steps of: 

a) receiving aggregated program schedule information for a plurality 
of service environments; 

b) identifying the program schedule information corresponding to a 
viewer's service environment; 

c) discarding program schedule information corresponding to service 
environments outside the viewer's; and 

d) storing the program schedule information not discarded. 

11. The schedule localization method according to claim 10 wherein a 
viewer's service envn-onment is described by a set of service groups, each service 
group identifying the service environment with a different level of specificity. 

12. The schedule localization method according to claim 1 1 wherem 
schedule data in the aggregated program schedule intended for a selected service 
environment includes address data representing the service group to which such 
schedule data pertains. 

13. The schedule localization method according to claim 12 wherein the 
step of identifying the program schedule information corresponding to a viewer's 
service environment includes the step of storing data representing each of the 
viewer's service groups and the step of comparing the address data in the 
aggregated program schedule with the stored service group data. 
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14. The schedule localization method according to claim 13 wherein 
schedule information in the aggregated program schedule intended for a selected 
service environment is stored if a match is found between the address data 
associated with such schedule information and the stored service group data 

5 representing at least one service group in the set of service groups to which the 
viewer is assigned. 

15. The schedule localization method according to claim 14 further 
comprising the step of providing an indication of the level of service environment 

10 specificity of each service group stored in the means for stormg service group data 
and the step of tagging stored schedule information with the indication 
corresponding to the service group on which a match with the address data of such 
schedule information was found. 

15 16. The schedule localization method accordmg to claim 15 further 

comprising the step of replacing stored schedule mformation with a new version of 
such schedule information if the service environment specificity indication 
associated with such new version is more specific to the viewer's service 
environment than the service environment specificity indication associated with the 

20 already stored schedule information. 

17. The schedule localization method according to claim 16 further 
comprising die step of rejecting a new version of schedule information already 
stored if the service environment specificity indication associated with such new 

25 version is less specific to the viewer's service environment than the service 
environment specificity indication associated with the already stored schedule 
information. 

18. The schedule localization method according to claim 10 wherein the 
30 service groups include geographic region and service provider. 

12 
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